/*
 * Copyright (c) 2005-2009 Flamingo Kirill Grouchnikov. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met:
 * 
 *  o Redistributions of source code must retain the above copyright notice, 
 *    this list of conditions and the following disclaimer. 
 *     
 *  o Redistributions in binary form must reproduce the above copyright notice, 
 *    this list of conditions and the following disclaimer in the documentation 
 *    and/or other materials provided with the distribution. 
 *     
 *  o Neither the name of Flamingo Kirill Grouchnikov nor the names of 
 *    its contributors may be used to endorse or promote products derived 
 *    from this software without specific prior written permission. 
 *     
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 
 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, 
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 */
package common;

import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.Point;
import java.awt.Rectangle;
import java.beans.PropertyChangeListener;
import java.util.List;

/**
 * Definition of a layout manager for {@link AbstractCommandButton}s.
 * 
 * @author Kirill Grouchnikov
 */
public interface CommandButtonLayoutManager extends PropertyChangeListener {
	/**
	 * Enumerates the available values for separator orientations.
	 * 
	 * @author Kirill Grouchnikov
	 */
	public enum CommandButtonSeparatorOrientation {
		/**
		 * Vertical separator orientation.
		 */
		VERTICAL,

		/**
		 * Horizontal separator orientation.
		 */
		HORIZONTAL
	}

	/**
	 * Layout information on a single line of text.
	 * 
	 * @author Kirill Grouchnikov
	 */
	public class TextLayoutInfo {
		/**
		 * Text itself.
		 */
		public String text;

		/**
		 * The text rectangle.
		 */
		public Rectangle textRect;
	}

	/**
	 * Layout information on different visual parts of a single command button.
	 * 
	 * @author Kirill Grouchnikov
	 */
	public class CommandButtonLayoutInfo {
		/**
		 * The action area. A mouse click in this area will trigger all
		 * listeners associated with the command button action model
		 * {@link AbstractCommandButton#addActionListener(java.awt.event.ActionListener)}
		 */
		public Rectangle actionClickArea;

		/**
		 * The popup area. A mouse click in this area will trigger the listener
		 * associated with the command button popup model
		 * {@link JCommandButton#setPopupCallback(org.jvnet.flamingo.common.popup.PopupPanelCallback)}
		 */
		public Rectangle popupClickArea;

		/**
		 * The separator area. If it's not empty, the command button will show a
		 * separator between {@link #actionClickArea} and
		 * {@link #popupClickArea} on mouse rollover - depending on the current
		 * look-and-feel.
		 */
		public Rectangle separatorArea;

		public CommandButtonSeparatorOrientation separatorOrientation;

		/**
		 * Rectangle for the command button icon.
		 */
		public Rectangle iconRect;

		/**
		 * Layout information for the command button text (that can span
		 * multiple lines).
		 */
		public List<TextLayoutInfo> textLayoutInfoList;

		/**
		 * Layout information for the command button extra text (that can span
		 * multiple lines).
		 */
		public List<TextLayoutInfo> extraTextLayoutInfoList;

		/**
		 * Rectangle for the icon associated with the {@link #popupClickArea}.
		 * This icon is usually a single or double arrow indicating that the
		 * command button has a popup area.
		 */
		public Rectangle popupActionRect;

		/**
		 * Indication whether the command button text (rectangles in
		 * {@link #textLayoutInfoList}) belongs in the action area.
		 */
		public boolean isTextInActionArea;
	}

	/**
	 * Returns the preferred size of the specified command button.
	 * 
	 * @param commandButton
	 *            Command button.
	 * @return The preferred size of the specified command button.
	 */
	public Dimension getPreferredSize(AbstractCommandButton commandButton);

	/**
	 * Returns the preferred icon size of command buttons which use this layout
	 * manager.
	 * 
	 * @return The preferred icon size of command buttons which use this layout
	 *         manager.
	 */
	public int getPreferredIconSize();

	/**
	 * Returns the anchor center point of the key tip of the specified command
	 * button.
	 * 
	 * @param commandButton
	 *            Command button.
	 * @return The anchor center point of the key tip of the specified command
	 *         button.
	 */
	public Point getKeyTipAnchorCenterPoint(AbstractCommandButton commandButton);

	/**
	 * Returns the layout information for the specified command button.
	 * 
	 * @param commandButton
	 *            Command button.
	 * @param g
	 *            Graphics context.
	 * @return The layout information for the specified command button.
	 */
	public CommandButtonLayoutInfo getLayoutInfo(
			AbstractCommandButton commandButton, Graphics g);
}
